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Appendix A 

Following is a pin definintion file for the master FPGA of a board of the present 
invention. 

5 

lllllllllllllllll/llllllllllllllllll/lllilllllllllllllllllillllllllllllllllll 

III HEADER FILE FOR MASTER FPGA 

/// 

lllllllllllllllllllllllllllllllllllllililli/llllllllllllllllll/llllllllllt/ll 

10 

#ifhdef _KOMPRESSOR_MASTER_HEADER 
#define KOMPRESSOR MASTER HEADER 

1 5 #warning CompiHng design for the Master FPGA 



// Set part and family numbers 

20 set part = "XV2000e-6-FG680"; 

set family = Xilinx4000E; // check there definitions 

llllllllllllllllllllllllllllllllllllllllllll 
II Clocks 

25 iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiin 



II CLKA 
// CLKB 
// MCLK 



A20 
D21 
AU22 
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//VCLK AW19 

// Only one clock is currently supported (HC2.1) 
set clock = external divide "A20" 2; 

5 

#define CLOCKRATE 25000000 // 50MHz clock / 2 
#define VGA // necessary for VGA driver 

10 

iiiiiiiiiiiiiiiiiiimiHHiiiiimiiiimiH 

II Master Slave definition Pin 

lllllllllllllllllllllllllllllllllllllllllllll 

15 macro expr MS_define = { data = {"C9"} } ; 



lllllllllllllllllllllllllllllllllllllllllllllllllllllllllilllllllllllllllllllll 
II Local SRAM definitions 
20 lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

lllllll/ll/llllllllll/llllllll 
II Local SRAM BANK 0 
// 

25 // Though this bank is defined to be 32bits wide. 
// it is possible to perform 8bit writes if required. 

Illlllllllllllllllllllllllllll 
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macro expr DA_pins = {"Wl", "AB4", "AB3", "W2", "AB2", "VI", "AA4", "V2", 
"AA3", "Ul", 

"W3", "U2", "W4", "TP, "V3", "T2", "V4", "V5", "U3", "R2", "U4", 
*T1", "U5", "P2", "T3", "Nl", "N2", "T4", "Ml", "R3", "M2", "R4"}; 

5 

macro expr AAjrins - {"LI", "L2", "N3", "Kl", "N4", "K2", "M3", "Jl", 
"L3", "J2", "L4", "HI", "K3", "H2", "K4", "Gl", "G2", "J3"}; 

macro expr CA_pins= {data = {"Fl", "J4", "F2", "H3", "El", "H4", "E2"}}; 

10 

macro expr sram_local_bankO_spec = 
{ 

offchip = 1, 

15 wegate = 1 , //we are using a divide 2 clock 
data = DA_pins, 
addr = AA_pins, 

cs = { "E2", "Fl", "J4", "F2", "H3"}, 
we ={"H4"}, 
20 oe = { "El" } 

}; 



25 



///////////////////////////// 
// Local SRAM Bank 1 

///////////////////////////// 
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macro expr DB_pins = {"AT3", "AP3", "AR3", "AT2", "AP4", "AR2", "ATI", "AN4", 
"AR1", 

"AN3", "AP2", "AN2", "API", "AM4", "AN1", "AM3", "AL4", "AM2", 

"AL3", 

5 "AMI", "AL2", "AL1", "AK4", "AK2", "AK3", "AK1", "AJ4", "AJ1", 

"AJ3", 

"AH2", "AJ2", "AH3"}; 

macro expr AB_pins = {"AGl", "AG4", "AF2", "AG3", "AF1", "AF4", "AF3", "AE2", 
10 "AE4", 

"AE1", "AE3", "AD2", "AD4", "AD1", "ACl", "AB1", "AC5", "AA2"}; 
macro expr CB_pins = {data = {"AC4", "AA1 ", "AC3", "Yl", "AC2", "Y2", "AB5"}}; 

15 

macro expr sram_local_bankl_spec = 
{ 

offchip = 1, 
wegate = 1, 
20 data = DB jpins, 
addr = AB_pins, 

cs = { "AB5 , V'AC4", "AA1", "AC3", "Yl" }, 
we ={"Y2"}, 
oe ={"AC2"} 
25 }; 



////////////////////////////// 
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// Shared SRAM definitions 

////////////////////////////// 

////////////////////////////// 
5 // Shared SRAM BANK 0 
// 

// Though this bank is defined to be 32bits wide. 
// it is possible to perform 8bit writes if required. 

///////////////////////////// 

10 

macro expr SHAREDRAMOA_pins = { "R37", "M39", "R36", "M38", "P37", "L39", 
"P36", "N37", "L38", "N36", "K39", "M37", "K38", 
"L37", "J39", "L36", "J38", "K37"}; 

15 macro expr SHAREDRAMOD_pins = { "AA39", "AB35", "Y38", "AB36", "Y39", 
"AB37", 

"AA36", "W39", "AA37", "W38", "W37", "V39", "W36", 
"U39", "V38", "U38", "V37", "T39", "V36", "T38", 
"V35", "R39", "U37", "U36", "R38", "U35", "P39", 
20 "T37", "P38", "T36", "N39", "N38"}; 

macro expr sram_shared_bankO_request__pin = { data = { "A17" }}; 
macro expr sram_shared_bankO_grant_pin = { data = { "B17" } } ; 

25 macro expr sram_shared_bankO_spec = 
{ 

offchip = 1 ? 
wegate = 1, 

data = SHAREDRAMOD _pins, 
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addr = SHAREDRAMOA_pins, 

cs = { "J36", "H39", "K36", "H38", "J37"}, 

we ={"G38" }, 

oe ={"G39"} 

s }; 



10 /////////////////////////// 
// Shared RAM bankl 
/////////////////////////// 



15 macro expr SH AREDRAM 1 A_pins = { "AH39", "AG38", "AG36", "AG39", "AG37", 
"AF39", "AF36", 

"AE38", "AF37", "AF38", "AE39", "AE36", "AD38", "AE37", 
"AD39", "AD36", "AC38", "AC39"}; 

20 macro expr SHAREDRAM 1 D_pins = { "AR37", "AR39", "AR36", "AT38", "AR38", 
"AP36", "AT39", 

"AP37", "APW, "AP39", "AN36", "AN38", "AN37", "AN39", 
"AM36", "AM38", "AM37", "AL36", "AM39", "AL37", "AL38", 
"AK36", "AL39", "AK37", "AK38", "AJ36", "AK39", "AJ37", 
25 "AJ38", "AH37", "AJ39", "AH38"} ; 

macro expr sram_shared_bankl_requestjpm = { data= { "D18" }}; 
macro expr sram_shared_bankl_grant_pin = { data = { "El 8" }}; 
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macro expr sramsharedbanklspec = 
{ 

offchip = 1, 
5 wegate = l, 

data = SHAREDRAM 1 D_pins, 

addr = SHAREDRAM 1 A_pins, 

cs = { "AC37","AD37", "AB38", "AC35", "AB39" }, 

we ={"AA38" }, 
10 oe ={"AC36"} 

}; 



15 IIIIIIIIIIIIIIIIIIHIIIIIII/llllllllllllllllllllilllllllllll 
II ARM Interfacing Pins 
lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

macro expr ARMAjpins = {data = { "A33", "C31", "B32", "B31", "A32", "D30", 
20 "A31", "C30", "B30", "D29"}}; 

macro expr ARMD_pins = {data= { "F39", "H37", "F38'\ "H36", "E39", "G37", 
"E38", 

"G36", "D39", "D38", "F36", "D37", "E37", "C38", 
25 "B37", "F37" 5 "D35", "B36", "C35", "A36", "D34", 

"B35", "C34", "A35", "D33", "B34", "C33", "A34", 
"B33", "D32", "C32", "D31"}}; 
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macro expr ARMGPIO_pins = {data= { "B9", "D10", "A9", "CIO", "BIO", "Dll", 
"A10", 

"Cll", "Bll", "C12", "All"}}; 



macro expr ARM_GPIO0_Pin = { data = { "Al 1"} } ; 
macro expr ARM_GPI01_Pin = { data= { "C12"}}; 

10 macro expr ARMnWE_pin = { data ={"A30"} }; // input 
macro expr ARMnOE_pin = { data ={"C29"} } ; //input 
macro expr ARMnCS4_pin = { data ={"A29"}}; // input 
macro expr ARMnCS5_pin = { data ={"B29"}}; // input 
macro expr ARMRDY_pin = { data ={"B28"}}; //ouput 

15 

llllillllllllllllillllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

II Flash Memory interface - may not be able to use definiton of Flash as a RAM if 
// FPGA to FPGA configuration is required 

20 llllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

macro expr FA_pins = { "D23", "A22", "E23", "B22", "B24", "A23", "C24", "B23", 
"A24", "D24", "A25", "C25", "B25", "D25", "A26", "C26", 
"D26", "B26", "C27", "A27", "D27'\ "B27", "C28", "A28"}; 

25 

macro exprFD_pins = {"AR4", "AH1", "AG2", "AD3", "Rl", "P3", "P4", "C2"}; // 
also to CPLD 
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macro expr FDH_pins = {"B19", "C21", "D22", "B20*\ "E22", "A21", "C23", "B21"}; 
//high byte of the RAM 

macro expr FC_pins = {"C18", "B18", "D19", "A18", "C19"}; // control pins j [oe| 
5 |we|cs 



macro expr flash_addr_spec = 
10 { 

offchip = 1, 
data = {}, 
addr = FAjpins, 
cs = { }, 
15 we ={}, 
oe ={} 

}; 

macro expr flash_data_spec = 
20 { 

offchip = 1, 
data = FD_pins, 
addr={}, 
cs ={"C19"}, 
25 we ={"A18"}, 
oe ={"B18"} 

}; 

macro expr flash_cs_pin = { data = {"CI 9"} }; 
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macro expr flash_oe_j>in = { data = {"B18"}}; 
macro expr flash_we_j)in = { data^ {"A18"}}; 

macro expr flash_stsj)in = {data = {"D19"}}; // status 
5 macro expr flash jiByte_pin = {data = {"C18"} } ; // x8 / xl6 selector 



10 lllllllllllllllllllllllllllllllllilllllllllllll 
II Parallel Port interface 

lllllllllllllllllllllllllllllllltllllllllllllll 

macro expr PP_pins = {data = { "C5", "A4", "D6", "B5", "C6" ? 
15 "AS", "D7", "B6", "C7'\ "A6'\ 



20 // ppo lines 12 11 10 9 8 6 4 2// pins 2 - 9 on the interface 

macro expr pp_dataj>ins - {data = { "C6", "AS", "D7", "B6" ? 

w C7 n , H D8 H , n C8 ,, , ,, D9"}}; 

25 // Status Port - write to host 



"D8", "B7", "C8", "A7", "D9", 
"B8", "A8"}}; 



macro expr nAckjpin = { data = { "B5"}}; 
macro expr busyjpin = { data = { "D6"}}; 
macro expr pe_j>in = { data = { "A4" } } ; 



//ppo 13 
//ppo 14 
//ppo 15 
//ppo 16 



macro expr select_pin = { data = { "C5"}}; 
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macro expr nErrorjpin = { data = { "A7"} } ; // ppo 3 

macro expr status_port_pins = { data= { "D6", "B5", "A4", "C5", "A7"}}; 



5 // Control Port - read from host 

macro expr nAutoFeed_pin = { data = { "B8"}}; // ppo 1 
macro expr init_pin = { data = { "B7"} } ; // ppo 5 
macro expr nSelect_in_pin = { data = { "A6"} } ; // ppo 7 
macro expr nStrobejpin = { data = { "A8"} } ; // ppo 0 

10 

//nSelectin, init, nautofeed, strobe, 

macro expr control_port_pins = {data= { "A6", "B7", "B8", "A8"}}; 

15 

llllllllllllltllllltlllllllHIIIIIIIIIllllllllll! 

II LEDs - maybe declare subsets and allocate each FPGA some 

lllllllllllllllllllllllllllllllllll/lllllll/lllll 

20 macro expr LED_pins = {data = { "AU27", "AW28", "AT26", "AV27", 

"AU26", "AW27", "AV26", "AT25"}}; 

lllllllllllllllllllllllllllllllllllllllllllllllllllll 
25 // ATA Interface 

lllllllllllllllllllllllllllllllllllllllllllllllllllll 

macro expr ATA_pins = {data= {"AW12", "AU14", "AV12", "AT14", "AU13", 
"AW11", "AT13", "AV11", "AU12", "AW10", "AUll", 
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"AV10", "AT11", "AW9", "AU10", "AV9", "ATIO", "AW8", 
"AU9", "AV8", "AW7", "AT9", "AV7", "AU8", "AW6", "AT8", 
"AV6", "AU7", "AW5", "AT7", "AW4", "AU6", "AV4"}}; 



5 



lillllllilllilllllllllllllllllllllllllllllllllllllHIIH 
II Expansion Bus (32 bits) 
llllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

10 

macro expr E_pins = {data= {"AU23", "AW21", "AV23", "AR22", "AV20", 
"AW20", "AV19", "AU21", "AW18", "AU19", 
"AV18", "AT19", "AW17", "AU18", "AV17", 
"ATI 8", "AW16", "AR18", "AVI 6", "AU17", 
15 "AT17", "AW15", "AR17", "AV15", "AU16", 

"AW14", "AT16", "AV14", "AW13", "AU15", 
"AV13", "AT15"}}; 



lllllllllllllllllllllllllllll 
II Serial H Bus 
//////////////////////////// 

macro expr SERIALH_pins = {data = {"G3", "G4", "D2", "F3", "D3", "F4", "Dl"}}; 



llllllllllllllllllllllllllllllllllllllllll 

II SelectLink Bus - Directly connects the 2 FPGAs 
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lllllllllillllllllHIlllllllllliHIIIIIIIII 

macro expr SL_pins = {data = { "AT34", "AU36", "AU34", "AV36", "AT33", 
"AW36", "AU33", "AV35", "AT32", "AW35", 
5 "AU32", " AV34", " AV32", " AW34", "AT3 1 

"AU31", "AV33", "AT30", "AW33", "AU30", 
"AW32", "AT29", "AV31", "AU29", "AW31", 
"AV29", "AV30", "AU28", "AW30", "AT27", 
"AW29", "AV28"}}; 



/////////////////////////// 
//VGA interface 
15 /////////////////////////// 

macro expr vga_vsync_pin = { data = { "AU25" } }; 
macro expr vga_hsync_pin = { data = { "AW26" } }; 

macro expr vga_data_pins = { data= { "AV25", "AT24", "AW25", "AU24", "AW24", 
20 "AW23", "AV24", "AV22", "AR23", "AW22", "AT23", "AV21"} }; 



// macros for compatibility with existing programs 

macro expr vsync_pin = { "AU25" }; 
25 macro expr hsync jpin = { "AW26" }; 

macro expr video_spec = { data = { "AV25", "AT24", "AW25", "AU24", 
"AW24", "AW23", "AV24", "AV22", 
"AR23", "AW22", "AT23", "AV21'*}}; 
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/////////////////////////// 
// CPLD interface pins 

5 /////////////////////////// 

macro expr BUSMasterjrin = { data= { "CI 7" }};//P12 
macro expr FPcom_pins = { data = { "B16", "El 7", "A15"}}; 



/////////////////////////// 
// Serial Port pins 
/////////////////////////// 

15 

macro expr rs232_txdjpin = {data = { "AT6"}}; 
macro expr rs232_rxd_pin = {data= { "AU4"}}; 
macro expr rs232_rtsjpin = {data = { "AV5"}}; 
macro expr rs232_cts_pin = {data= { "AV3"}}; 

20 

Illllll/llllillllllltlllllllllllllllllllll/IIIIIIIIIIIIIIIIIIIIIIIIIIII 
//USB 

llllllltlllllllllillllllilllllllllllllllllllllllllllllllllllllllllllllll 

25 

macro expr USBMaster_pin = { data = { "D17" }}; 



macro expr USBD_pins = {data= {"D15", "B13", "C14", "A12", "D14", "C13", "B12", 
"D13"}}; 
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macro expr USBMS jpins = { data= {"CI 6"} }; 
macro expr USBnRST_pins = { data = {"B15"} }; 

5 

macro expr USBIRQ_pins = { data = {"D16"} }; 
macro expr USB AO _pins = { data= {"A14"} }; 
1 0 macro expr USBnRD_pins = { data = {"B 14"} } ; 
macro expr USBnWR_pins = { data = {"C15"} }; 
macro expr USBnCS_pins = { data = {"A13"} }; 

15 

#endif // _KOMPRESSOR_MASTER_HEADER 



20 
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Appendix B 

Following is a pin definition file for a slave FPGA of a board according to an 
embodiment of the present invention. 

5 

IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII 
III 

III HEADER FILE FOR SLAVE FPGA - DEFINE FP1 IN THE MAIN SOURCE FILE 

/// 

10 lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 



#imdef_KOMPRESSOR_SLAVE_HEADER 
#define _KOMPRESSOR_SLAVE_HEADER 

15 

#warning Compiling design for the Slave FPGA 



set part = "XV2000e-6-FG680"; 
20 set family = Xilinx4000E; 



25 llllllllllllllllllllllllllllllllllllllllllll 
II Clocks 

llllllllllllllllllllllllllllllllllllllllllll 
II CLKA D21 
// CLKB A20 
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// MCLK AW19 
//VCLK AU22 

// Only one clock is currently supported (HC2.1) 

5 

set clock = external_divide "D21 " 2; 

#define CLOCK_RATE 25000000 // 50MHz clock / 2 

10 

#define VGA // necessary for VGA driver 



llllllllllllllllllllllllllllllllllllllll/llll 
15 // Master Slave definition Pin 
fllllllllllllflllllllllllllllllllllMllllllI 



macro expr MS_defme = { data = {"D33"}}; 



20 



IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIHIIIIIIIIIIIIIIIHIIIHKI 
II Local SRAM definitions 

lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

IHllllllllllHIIIIIIHlllllH 
II Local SRAM BANK 0 
// 

// Though this bank is defined to be 32bits wide. 
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// it is possible to perform 8bit writes if required. 

////////////////////////////// 



5 macro expr DA_pins = { "AA39", "AB35", "Y38", "AB36", "Y39", "AB37", 
"AA36", "W39", 

"AA37", "W38'\ "W37", "V39", "W36", 

"U39", "V38", "U38", 

"V37", "T39", "V36","T38", "V35", 

10 "R39", "U37", "U36", 

"R38", "U35", "P39", "T37", "P38", 

"T36", "N39", "N38" }; 

macro expr AA_pins= { "R37", "M39", "R36", "M38", "P37", "L39", "P36", "N37", 
15 "L38", "N36", "K39", "M37", "K38", 

"L37", "J39", "L36", 

"J38", "K37"}; 

macro expr CA_pins= {data = {"H39", "K36", "H38", "J37", "G39", "G38", "J36"}}; 

20 



macro expr sramlocalbankOspec = 
{ 

25 offchip = 1 , 

wegate = 1 ? 
data = D A_pins, 
addr = AA_pins, 

cs = { "J36", "H38", "J37", "K36", "H39" } ? 
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10 



25 



we ={"G38"}, 

oe = { "G39"} 

}; 



///////////////////////////// 

// Local SRAM Bank 1 

///////////////////////////// 



macro expr DB_pins = { "AR37", "AR39", "AR36", "AT38", "AR38", "AP36", 
"AT39", "AP37", 

"AP38", "AP39", "AN36", "AN38", 

"AN37", "AN39", "AM36", "AM38", 
15 "AM37", "AL36", "AM39", "AL37", 

"AL38", "AK36", "AL39", "AK37", 

"AK38", "AJ36", "AK39", "AJ37", 

"AJ38", "AH37", "AJ39", "AH38"}; 

20 macro expr AB_pins - { { "AH39", "AG38", "AG36", "AG39", "AG37", "AF39", 
"AF36", "AE38", 

"AF37", "AF38", "AE39", "AE36", 

"AD38", "AE37", "AD39", "AD36", 

"AC38", "AC39"}}; 



macro expr CB_pins = {data = {"AD37", "AB38", "AC35", "AB39", "AC36", "AA38", 
"AC37"}}; 

macro expr sram local bankl spec = 
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{ 

offchip = 1, 
wegate = 1, 

data = DB_pins, 
5 addr = ABjrins, 

cs = { "AB38", "AD37", "AB39", "AC35", "AC37" }, 
we = {"AA38"}, 

oe - { "AC36"} 

}; 

10 



15 ////////////////////////////// 

// Shared SRAM definitions 

////////////////////////////// 

20 ////////////////////////////// 

//Shared SRAM BANK 0 

// 

// Though this bank is defined to be 32bits wide. 
// it is possible to perform 8bit writes if required. 

25 ///////////////////////////// 

macro expr SHAREDRAMOAjpins = { "LI", "L2", "N3 ", "Kl ", "N4", "K2", 
"M3", "Jl", 
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"L3", "J2", "L4", "HI", 

"K3", "H2", "K4", "Gl", 

"G2", "J3"}; 

5 

macro expr SHAREDRAMOD_pins = { "Wl ", "AB4", "AB3", "W2", "AB2", 
"VI", "AA4", "V2", 

"AA3", "Ul", "W3", "U2", 

"W4","T1", "V3", "T2", 
10 "V4VV5", "U3", "R2", 

"U4","P1", "U5", "P2", 

"T3", "Nl", "N2", "T4", 

"M1","R3", "M2", "R4"}; 

15 

macro expr sram_shared_bankO_request_pin = { data = { "A25" }}; 
macro expr sram_shared_bankO_grant_pin = { data = { "B25" }}; 

macro expr sram shared bankO spec = 
20 { 

offchip = 1, 

data = SHAREDRAMODjpins, 
addr = SHAREDRAMOAjpins, 
cs = { "E2", *'H3", "F2", "J4", "Fl"}, 
25 we ={"H4"}, 

oe = { "El" } 

}; 
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/////////////////////////// 
// Shared RAM bankl 

/////////////////////////// 

5 

macro expr SHAREDRAM 1 A_pins = {"AG1", "AG4", "AF2", "AG3", "AF1", 
"AF4", "AF3", "AE2", 

"AE4", "AE1 ", "AE3", 

"AD2", "AD4", "AD1", "AC1", "AB1", 
10 "AC5","AA2"}; 

macro expr SHAREDRAM 1 D_pins = { "AT3", "AP3", "AR3", "AT2", "AP4", 
"AR2", "ATI", "AN4", 

"AR1 ", "AN3", "AP2", 

15 "AN2", "API", "AM4", "AN1", "AM3", 

"AL4", "AM2", "AL3", 

"AMI", "AL2", "AL1", "AK4", "AK2", 

"AK3", "AK1 ", "AJ4", 

"AJ1", "AJ3", "AH2", "AJ2", "AH3"}; 

20 

macro expr sram_shared_bankl_request_pin = { data = { "C25" }}; 
macro expr sram_shared_bankl_grant_pm = { data = { "D25" }}; 

25 macro expr sram shared bankl spec = 
{ 

offchip = 1, 

wegate = 1, 
data = SHAREDRAM lD_pins 5 
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addr = SHAREDRAM 1 A_pins, 

cs = { "AB5", "AC3", "Yl", "AA1", "AC4" }, 

we ={"Y2"}, 

oe = { "ACT' } 

5 }; 



10 



15 



20 



lllllllllll/llllllllllilllllllllilllllllllllllllllllllllillll 
II ARM Interfacing Pins 
lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 



macro expr ARMA_pins = {data= { "Cll", "BIT, "C12", "All", "D13", 

"B12", "C13", "D14", 

"A12", "C14"}}; 



macro expr ARMD_pins = {data = {"G3", "G4", "D2", "F3", "D3'\ 

"F4", "Dl", "C5", "A4", 

"D6", 

"B5", "C6", "A5", "D7", 

25 "B6", 

"C7", "A6", "D8", "B7", 

"C8", 

"A7", "D9", "B8", "A8", 

"C9", 
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"B9", "D10","A9", 

"BIOV'CIO", 

"Dll", "A10"}}; 

5 

macro expr ARMGPIO_pins = {data = { "B34", "C33", "A34", "D32", "B33", 
"C32", 



"D31", "A33", 



"C31", "B32", "B31"}}; 

10 

macro expr ARMnWE_pin = { data ={"B13"}}; // input 
macro expr ARMnOE_pin = { data ={"D15"}}; //input 
macro expr ARMnCS4_pin = { data ={"A13"}}; // input 
15 macro expr ARMnCS5jpin = { data ={"C15"}}; // input 
macro expr ARMRDY_pin = { data ={"B14"} }; //ouput 



20 



llllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

II Flash Memory interface - may not be able to use definiton of Flash as a RAM if 
25 // FPGA to FPGA configuration is required 

llllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 



macro expr FA_pins = { "E22", "B20", "D22", "C21", "B19", "C19", "A18", 
"D19", 
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"B18", "C18", "A17", "D18", "B17", 

"E18", "A16", "C17", 

"D17", "B16", "E17", "A15", "C16", 

"B15", "D16", "A14"}; 

macro expr FD_pins = {"AR4", "AH1", "AG2", "AD3", "Rl", "P3", "P4\ "C2"}; // 
also to CPLD 

macro expr FDH_pins = {"B24", "B22*\ "E23", "A22", "D23", "B21", "C23", "A21"}; 
//high byte of the RAM 

macro expr FC_pins = {"D24", "A24", "B23", "C24", "A23"};//d // control pins | |oe| 
|we|cs 

macro expr flash_addr_spec = 

{ 

offchip= 1, 
data= {}, 
addr = FA_pins, 
cs = {}, 
we ={}, 

oe ={} 

}; 

macro expr flash_data_spec = 
{ 

offchip = 1, 
data = FD_pms, 
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addr= {}, 

cs ={"A23"}, 

we = {"C25"}, 

oe = { "A24"} 

5 }; 



macro expr flash_csj>in = { data = {"A23"}}; 
macro expr flash_oejpin = { data = {"A24"}}; 
macro expr flashjvejpin = { data = {"C25"}}; 

10 

macro expr flash_sts_pin = {data = {"B23"} } ; // status 

macro expr flash_nByte_pin = {data = {"B24"} } ; // x8 / xl6 selector 



lllllllllllllllllllllllllllllllllllllllllllllll 
II Parallel Port interface 

lllllllllllllllllllllllllllllllllllllllllllllll 

20 

macro expr PP_pins = {data = { 
"F37", "D35", 
25 "D34", "B35'\ 
pins 



'G36'\ "039", M D38", "F36", "D37" ? 

"E37", "C38", "B37", 

"B36", "C35", "A36", 

"C34", "A35"}};//allthe 
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// ppo lines 12 1 1 1 0 9 8 6 4 111 pins 2 - 9 on the interface 

macro expr pp_data_j>ins = {data - { "D37", "E37", "C38", "B37", 

"F37", "B36'\ 

"A36'\ "B35"}}; 

5 

// Status Port - write to host 

macro expr nAck_pin = { data = { "F36"} } ; // ppo 13 
macro expr busyj>in = { data = { "D38"}}; // ppo 14 
10 macro expr pe jin = { data = { "D39"} } ; // ppo 1 5 
macro expr select__pin = { data = { "G36"} } ; // ppo 16 
macro expr nErrorjpin = { data = { "D34"} }; // ppo 3 

//busy @ nAck @ pe @ Select @ nError; 
15 macro expr status j>ort_j>ins = { data = { "D38", "F36 n , "D39", "G36", "D34"}}; 

// Control Port - read from host 

macro expr nAutoFeedj>in = { data = { "C34"} } ; // ppo 1 
macro expr initjpin = { data = { "C35"}}; // ppo 5 
20 macro expr nSelect__in_j>in = { data = { "D35"}}; // ppo 7 
macro expr nStrobejpin = { data = { " A35"} } ; // ppo 0 

//nSelectin, init, nautofeed, strobe, 

macro expr control_port_j)ins - { data= { "D35", "C35 M , n C34 w , "A35"}}; 

25 



lllllllllllllllllllllllllllllllllllllllllllllllll 



